import type { VxeTableGridOptions } from '@vben/plugins/vxe-table';

import type { VbenFormSchema } from '#/adapter/form';
import type { DictApi, RepairApi } from '#/api';

import { reactive } from 'vue';

import { DictResp } from '#/api';

// const switchValue = ref('');

const mes_repair_result = reactive<DictApi.SelectOption[]>([]);
const mes_order_status = reactive<DictApi.SelectOption[]>([]);
const dv_plan_type = reactive<DictApi.SelectOption[]>([]);

DictResp(['mes_repair_result', 'mes_order_status', 'dv_plan_type']).then(
  (res) => {
    // 将两个数组合并
    if (res.mes_repair_result) {
      mes_repair_result.push(...res.mes_repair_result);
    }
    if (res.mes_order_status) {
      mes_order_status.push(...res.mes_order_status);
    }
    if (res.dv_plan_type) {
      dv_plan_type.push(...res.dv_plan_type);
    }
  },
);

export function useSearchForm(): VbenFormSchema[] {
  return [
    {
      component: 'Input',
      componentProps: {
        placeholder: '请输入维修单编号',
        class: 'mr-5',
      },
      fieldName: 'repairCode',
      label: '维修单编号',
      labelClass: 'text-[#606266] font-bold',
    },
    {
      component: 'Input',
      componentProps: {
        placeholder: '请输入计划名称',
      },
      fieldName: 'repairName',
      label: '维修单名称',
      labelClass: 'text-[#606266] font-bold',
    },
    {
      component: 'Input',
      componentProps: {
        placeholder: '请输入设备编码',
      },
      fieldName: 'machineryCode',
      label: '设备编码',
      labelClass: 'text-[#606266] font-bold',
    },
    {
      component: 'Input',
      componentProps: {
        placeholder: '请输入设备名称',
      },
      fieldName: 'machineryName',
      label: '设备名称',
      labelClass: 'text-[#606266] font-bold',
    },
    {
      component: 'Select',
      componentProps: {
        allowClear: true,
        filterOption: true,
        options: mes_repair_result,
        placeholder: '请选择',
        showSearch: true,
      },
      fieldName: 'repairResult',
      label: '维修结果',
      labelClass: 'text-[#606266] font-bold',
    },
    {
      component: 'Select',
      componentProps: {
        allowClear: true,
        filterOption: true,
        options: mes_order_status,
        placeholder: '请选择',
        showSearch: true,
      },
      fieldName: 'status',
      label: '单据状态',
      labelClass: 'text-[#606266] font-bold',
    },
  ];
}

/**
 * 获取编辑表单的字段配置
 */
export function useSchema(): VbenFormSchema[] {
  return [
    // {
    //   component: 'Input',
    //   fieldName: 'planId',
    //   dependencies: {
    //     triggerFields: ['planId'],
    //     show: false,
    //   },
    // },
    // {
    //   component: 'Input',
    //   fieldName: 'planCode',
    //   label: '计划编号',
    //   rules: 'required',
    //   formItemClass: 'col-span-1',
    //   componentProps: {
    //     placeholder: '请输入计划编号',
    //   },
    //   dependencies: {
    //     triggerFields: ['switch'],
    //     trigger(values) {
    //       values.planCode = switchValue;
    //     },
    //   },
    // },
    // {
    //   component: 'Switch',
    //   fieldName: 'switch',
    //   label: '自动生成',
    //   formItemClass: 'col-span-1',
    //   componentProps: {
    //     defaultValue: 0,
    //     onChange: (e: boolean) => {
    //       if (e) {
    //         getAutoCode('CHECKPLAN_CODE').then((res) => {
    //           switchValue.value = res.data;
    //         });
    //       } else {
    //         switchValue.value = '';
    //       }
    //     },
    //   },
    //   dependencies: {
    //     triggerFields: ['planId'],
    //     show(values) {
    //       return !values.planId && true;
    //     },
    //   },
    // },
    // {
    //   component: 'Input',
    //   fieldName: 'planName',
    //   label: '计划名称',
    //   componentProps: {
    //     placeholder: '请输入计划名称',
    //   },
    //   formItemClass: 'col-span-2 col-start-3',
    // },
    // {
    //   component: 'Select',
    //   rules: 'required',
    //   componentProps: {
    //     allowClear: true,
    //     filterOption: true,
    //     options: dv_plan_type,
    //     placeholder: '请选择类型',
    //     showSearch: true,
    //   },
    //   fieldName: 'planType',
    //   label: '计划类型',
    //   formItemClass: 'col-span-1 col-start-1',
    // },
    // {
    //   component: 'ElInputNumber',
    //   fieldName: 'cycleCount',
    //   formItemClass: 'col-span-1 col-start-3',
    //   label: '频率',
    //   rules: 'required',
    //   defaultValue: 1,
    //   componentProps: {
    //     min: 0,
    //     controls: true,
    //   },
    // },
    // {
    //   component: 'Select',
    //   rules: 'required',
    //   componentProps: {
    //     allowClear: true,
    //     filterOption: true,
    //     options: mes_repair_result,
    //     placeholder: '请选择频率',
    //     showSearch: true,
    //   },
    //   labelClass: 'hidden',
    //   fieldName: 'cycleType',
    //   formItemClass: 'col-span-1',
    // },
    // {
    //   component: 'RangePicker',
    //   fieldName: 'rangePicker',
    //   label: '开始结束时间',
    //   formItemClass: 'col-span-2',
    // },
    // {
    //   component: 'Select',
    //   disabled: true,
    //   defaultValue: 'PREPARE',
    //   componentProps: {
    //     allowClear: true,
    //     filterOption: true,
    //     options: mes_order_status,
    //     placeholder: '请选择状态',
    //     showSearch: true,
    //   },
    //   label: '状态',
    //   fieldName: 'status',
    //   formItemClass: 'col-span-1 col-start-3',
    // },
    // {
    //   component: 'Textarea',
    //   componentProps: {
    //     placeholder: '请输入标准',
    //     rows: 3,
    //     showCount: true,
    //   },
    //   fieldName: 'remark',
    //   label: '备注',
    //   emptyStateValue: null,
    //   formItemClass: 'col-span-4',
    // },
  ];
}

/**
 * 获取表格列配置
 */
export function useColumns(): VxeTableGridOptions<RepairApi.Row>['columns'] {
  return [
    {
      field: 'checkbox',
      fixed: 'left',
      type: 'checkbox',
      width: 50,
    },
    {
      title: '维修单编号',
      field: 'repairCode',
      width: 150,
    },
    {
      title: '维修单名称',
      field: 'repairName',
    },
    {
      field: 'machineryCode',
      title: '设备编码',
    },
    {
      field: 'machineryName',
      title: '设备名称',
    },
    {
      title: '报修日期',
      field: 'requireDate',
    },
    {
      title: '维修完成日期',
      field: 'finishDate',
    },
    {
      title: '验收日期',
      field: 'confirmDate',
    },
    {
      title: '维修结果',
      field: 'repairResult',
    },
    {
      title: '维修人员',
      field: 'createBy',
    },
    {
      field: 'confirmBy',
      title: '验收人员',
    },
    {
      field: 'status',
      title: '单据状态',
      formatter: ({ cellValue }) => {
        const item = mes_order_status.find((item) => item.value === cellValue);
        return item?.label || '-';
      },
    },
    {
      field: 'action',
      title: '操作',
      width: 150,
      fixed: 'right',
      align: 'center',
      slots: { default: 'action' },
    },
  ];
}
